![](data:image/png;base64,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)

ISTD 50.002 Computation Structures

**Lab #7 Trap Handler**

[Introduction](#_7so9tl29tmpv)

[Due Date](#_2et92p0)

[Task Implement LDB and STB instructions](#_ubbxmjwurbqc)

[LDB](#_spfuqdbanj7)

[STB](#_z4nd3rkrk65b)

[Test Your Code](#_1f3opsk2obu7)

Revamped by: Kenny Choo, Natalie Agus, Oka Kurniawan 2020.

# Introduction

The goal of this lab is to add support for **two new instructions to the Beta**. But instead of adding hardware, we will support the instructions *in software* (!) by writing the appropriate emulation code in the handler for “illegal instruction” exceptions.

## Due Date

Refer to the [course handout](https://docs.google.com/document/d/10G-WRqCuoDnmcUJH6keefA_oOU1KshD1UI8jnKo4dig/edit?usp=sharing) for due date.

# Task Implement LDB and STB instructions

The new instructions implement load (LDB) and store (STB) operations for byte (8-bit) data.

## **LDB**

Usage: LDB(Ra, literal, Rc)

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Opcode: | 010000 | Rc | Ra | literal |

Operation: PC ← PC+4

EA ← Reg[Ra] + SEXT(literal)

MDATA ← Mem[EA]

Reg[Rc]7:0 ← if EA1:0 = 0b00 then MDATA7:0

else if EA1:0 = 0b01 then MDATA15:8

else if EA1:0 = 0b10 then MDATA23:16

else if EA1:0 = 0b11 then MDATA31:24

Reg[Rc]31:8 ← if EA1:0 = 0b00 then MDATA7:0

## **STB**

Usage: STB(Rc, literal, Ra)

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Opcode: | 010001 | Rc | Ra | literal |

Operation: PC ← PC+4

EA ← Reg[Ra] + SEXT(literal)

MDATA ← Mem[EA]

if EA1:0 = 0b00 then MDATA7:0 ← Reg[Rc]7:0

else if EA1:0 = 0b01 then MDATA15:8 ← Reg[Rc]7:0

else if EA1:0 = 0b01 then MDATA23:16 ← Reg[Rc]7:0

else if EA1:0 = 0b01 then MDATA31:24 ← Reg[Rc]7:0

Mem[EA] ← MData

The effective address EA is computed by adding the contents of register Ra to the sign-extended 16-bit displacement literal. The low-order 8-bits of register Rc are written into the byte location in memory specified by EA. **The other bytes of the memory word remain unchanged**.

When the Beta hardware (which does not know about these instructions) detects either of the two opcodes above, it will cause an “illegal instruction” exception (see section 6.4 of the [Beta documentation](https://drive.google.com/file/d/1L4TXMEDgD5gTN2JSd4ea_APpwNKUpzqK/view?usp=sharing)) and set the PC to 4.

The checkoff code has loaded location 4 with “BR(UI)” that branches to an assembly language routine labeled UI which handles illegal instructions – **this is the routine that you need to write**. It should do the following:

1. Determine if the opcode for the illegal instruction is for LDB or STB. The address of the instruction after the illegal instruction has been loaded into register XP by the hardware (i.e., the illegal instruction is at memory address Reg[XP]-4).
2. If the illegal instruction is not LDB or STB, your routine should branch to the label \_IllegalInstruction – note the leading underscore. Before branching, the contents of all the registers should be the same as they were when your routine was entered. So you should save and restore any registers you use in Step 1.
3. If the illegal instruction is LDB or STB, your routine should perform the appropriate memory and register accesses to emulate the operation of these instructions. Your routine will have to decode the instruction at Reg[XP]-4 to determine what registers and memory locations to use.
4. When your emulation is complete, return control to the interrupted program at the instruction following the LDB or STB. The contents of all the registers should be the same as they were when your routine was entered, except for the register changed by LDB. So you need to save and restore any registers you use in steps 1 and 3.

## Test Your Code

To test your code, we will be using the BSim beta simulator. In order to interface properly with the checkoff code, your assembly language program should follow the template below:

|  |
| --- |
| .include /50002/beta.uasm  .include /50002/lab7checkoff.uasm  UI:  … your assembly language code here … |

**Lab7checkoff.uasm contains the checkoff code for this lab.** When execution begins, it does the appropriate initialization (setting SP to point to an area of memory used for the stack, etc.) and then executes a small test program that includes LDB and STB instructions that test your emulation routine. The program will type out messages as it executes, reporting any errors it detects. **When it types “Checkoff tests completed successfully!”, you are ready to submit your code to the online checkoff system. Remember, use VPN!**

To help you get started here is an example illegal instruction handler that emulates a new instruction swapreg(RA, RC) which interchanges the values in registers RA and RC. This example can be found online in /50002/swapregs.uasm. The example includes lab7macros.uasm, a file containing some useful macros for saving/restoring registers and extracting bit fields from a 32-bit word.

|  |
| --- |
| .include /50002/beta.uasm  .include /50002/lab7macros.uasm  ||| Handler for opcode 1 extension:  ||| swapreg(RA,RC) swaps the contents of the two named registers.  ||| UASM defn = .macro swapreg(RA,RC) betaopc(0x01,RA,0,RC)  regs: RESERVE(32) | Array used to store register contents  UI:  save\_all\_regs(regs)    LD(xp,-4,r0) | illegal instruction  extract\_field(r0, 31, 26, r1) | extract opcode, bits 31:26  CMPEQC(r1,0x1,r2) | OPCODE=1?  BT(r2, swapreg) | yes, handle the swapreg instruction.  LD(r31,regs,r0) | It’s something else. Restore regs  LD(r31,regs+4,r1) | we've used, and go to the system's  LD(r31,regs+8,r2) | Illegal Instruction handler.  BR(\_IllegalInstruction)  swapreg:  extract\_field(r0, 25, 21, r1) | extract rc field  MULC(r1, 4, r1) | convert to byte offset into regs array  extract\_field(r0, 20, 16, r2) | extract ra  MULC(r2, 4, r2) | convert to byte offset into regs array  LD(r1, regs, r3) | r3 <- regs[rc]  LD(r2, regs, r4) | r4 <- regs[ra]  ST(r4, regs, r1) | regs[rc] <- old regs[ra]  ST(r3, regs, r2) | regs[ra] <- old regs[rc]    restore\_all\_regs(regs)  JMP(xp) |